The idea
for the project TPTP Web TEST, in the following briefly named as Web TEST, resulted from the vocational background of the author
of this paper. The author, Günter Öller, is involved as Web developers at the
company MathConsult GmbH [3] in the development of the product UnRisk FACTORY
[4]. UnRisk FACTORY is a HTML-based application for the intranet. In this web application
the HTML sides are generated by a Web server. In the following chapters this
kind of application is called HTML-based web application.
UnRisk
FACTORY is used by banks and other financial service providers in the Intranet,
in order the value of financial products to estimate and to supervise be able.
In the past
it came often to problems while developing UnRisk FACTORY. New versions of the
product contained errors, which were already repaired in previous versions,
which led among other things to a degradation of the product image. The problem
is that failures in certain services occur after changes in a wholly different
service. Illustration 1.1 illustrates this problem.
Illustration11: Unidentified error by a new
version of application
As
illustration 1.1 represents, it can come by a change of a service A to an error
in another service B that is based on A, although B was not changed itself and
was perhaps not tested again therefore. In order to prevent this type of error,
one can use a test procedure, which compares the unchanged services of a new
version with the previous version. This kind of testing is called regression
testing and is described in chapter 2.3 “Regression tests of HTML-based web
applications” more
detailed.
For UnRisk
FACTORY due to this type of error it was decided that regression tests must be
accomplished. In order to manage this, a employee was
used as tester, in order to accomplish the comparisons manually. Since this
work turned out as very time-consuming and for the tester discouraging task,
the task was handed over to the author of this work to look for a supporting
test tool.
For this purpose, among other things, the
following tools were tested:
With the evaluation of these tools however the
following points were determined as insufficient:
To the
explanation of the last point: UnRisk FACTORY uses frequently HTML sides with a
table with two columns, as presented in illustration 1.2, in order to show
information.
Illustration12: A table with two columns in UnRisk
FACTORY with attributes as pairs of name-values
Whereby the
first column contains the name of an attribute and the second column contains the
pertinent value. A usable tool must use this uniformity and the test for all
these attributes must be generated with few steps. An important boundary
condition is that the number of necessary steps to create the test for all
attributes does not depend on the number of lines in the indicated table.
Further
tools were tested, which permit it to save a snapshot of an HTML side and to
compare this snapshot with the test execution. This picture comparison has
however the disadvantage that no parameter of a side may change so that the
test verdict is successful. In UnRisk FACTORY and in many similar applications however
a modification date is indicated that from test admission to test execution
changes.
A further
alternative are test tools, which permit it to indicate a maximum change rate.
This rate defines how much per cent a HTML side from the recording to the test
execution may change. Unfortunately, also this procedure was classified as
insufficient for UnRisk FACTORY. When testing UnRisk FACTORY it is important to
examine the value of certain fields exactly and other fields, as for instance a
modification date, need not to be examined.
Since none
of these tools could convince, MathConsult decided to accomplish the tests
further manually. The author of this work became however attentive by the
evaluation process to the Eclipse test platform TPTP. This Framework already
offers the fundamental services for accomplishing regression tests. TPTP
supported both recording user scenarios of HTML-based Web applications, and the
administration and replaying of these scenarios. Just the functions to
administer test conditions for contents from HTML sides and to examine these
during the test execution are missing. And furthermore TPTP is designed to make
coherent extensions possible. The source code is public under the Eclipse Public
Licence (EPL) [14]. Therefore it is possible to extend TPTP with these
additional required features. Due to this consideration the project TPTP Web
TEST was started.
In the
context of the project TPTP Web TEST three goals are to be united with one
another:
The company
MathConsult needs a tool, which supports the test process that is illustrated
in illustration 1.3 for testing UnRisk FACTORY.
Illustration13: Demanded application for Web test
Illustration
1.3 shows, of which steps the demanded test process consists:
The step 2,
in which the test conditions are provided, is substantial for the Web TEST
project. Specially in this point Web TEST must differ
from the evaluated test tools. The following functions must be offered:
The last
one of the two functions addressed here helps the tester of UnRisk FACTORY
extraordinarily. Like before already mentions, UnRisk FACTORY indicates a great
amount of information in tables with two columns. Whereby each line describes
one attribute of an object of UnRisk FACTORY. Each attribute has a name and a
value. During the test execution then the object attributes must have the same
values as in the test admission.
Illustration14: Object attributes of a test admission
and a test execution in UnRisk Factory
Illustration
1.4 shows twice the same piece of a HTML side of UnRisk FACTORY. On the left
half the condition is represented, which is supposed correctly in an older
UnRisk FACTORY version. On the right half the condition of the HTML side is
represented, which are shown when manual accomplishing a regression test with a
new version of UnRisk FACTORY. If one
compares the lines of the shown tables, then one recognizes that these are
identical up to the line “Modification Date”. Thus the manual regression test has
a successful verdict. If one actually performs this manual regression test,
then one notices that manual examining of the values is very time-consuming and
error-prone. Among other things, because one can easily mix a
line or the often similar values. Further it is to be noted that there
are hundreds of different object types and thus hundreds of these tables in
UnRisk FACTORY, which must be tested.
The
automatic production of the test conditions from the test pages and the program
controlled comparison during the test execution are therefore a substantial
easement for the tester. Not only the tester is relieved, but also the quality
of the test is increased.
This work
describes the implementation of the requirements described before in the
context of the TPTP Web TEST project and is structured content-wise as follows:
§
In chapter 2” “Methods for functional
testing of HTML-based web application” the usable test methods are presented
and it is specified, which test method is used in the tool Web TEST.
§
In chapter 3 “How to use Web TEST” the
tool Web TEST is presented from a user viewpoint. With the help of an use case scenario it is demonstrated, how a user uses Web
TEST.
§
In chapter 4 “The TPTP Framework” the
Eclipse test Framework TPTP is introduced, which is used by Web test.
§
In chapter 5 “The Implementation of Web
TEST” the architecture and the interfaces of Web TEST are discussed.
§
In chapter 6 “Preview and conclusion” an
overview of possible extensions is given. Finally, in this chapter the personal
assess of the author for the tool Web TEST is stated.
Common and
technical terms, abbreviations and foreign words usual in computer science are
not particularly set in the text and no glossary of all used expressions is
offered. Not common and technical terms, abbreviations and foreign words
uncommon in computer science are explained with their first use in the text or
are provided with a literature reference. Further these expressions are set
with their first use in italic writing. With each further use these expressions
will not be explained again and then they are not particularly set any longer.
Compound foreign words and names are represented with hyphen. In addition in
the case of the first translation of an English term (for example from tables,
diagrams or of technical terms) the English form in clammy ones is noted after
the translation. This notation is also used, if in the text synonyms are used
for terms from tables and diagrams. Names of elements in user interface
snapshots (labels), file names, paths and values of attributes from diagrams
and tables are marked by quotation marks.
… the other chapter’s will follow as soon as I have some time
and a better translation tool ;-) … kind regards, Gunter